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(54) Information processing equipment and IC card 

(57) An IC card (101) having a storage memory 
(204) including a program storage unit for storing a pro- 
gram and a data storage unit for storing data and a cen- 
tral processing unit (201) for executing a predetermined 
process in accordance with the program to process the 
data, the program including one or more data process 
units each having a process instruction for giving an 
execution instruction to the central processing unit, 
wherein a data process order is randomly exchanged 
and a dummy process is added to thereby reduce the 
dependency of consumption current of an IC chip upon 
the data process. 
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Description 

BACKGROUND OF THE INVENTION 

[0 0011 Tbe present invention,^ to an into— processing eguipmen, and .ore par ti cular,y to a tamper 

resistance device such as an IC card (smart cart > n h ^^ so as not to be altered by a third party or for 

[0002] An IC card is mainly used for stormg mformat o .n a .mum* so jnce ^ |C ^ js notpro . 

nication Engineers. structure that an IC card chip 102 is fabricated on a card 101 . A gen- 

[0003] As shown in Fig. 1 , an IC card has the structure that an iu ra^ h transferred, 
era. IC card has contacts via which a power V^E^jSlSE microcomputer. As shown in Fig. 2. the IC 
[0004] The structure of an IC card ch.p .s bas.ca.ly the > same as that of a v» P ^ & essor 202 . 

card chip includes a central processor 201 a ^T^Sfi^ and the storage memory 204 stores programs 
The cenW. processor 201 executes logical and anthmejc «te£J«£dft. 9 ^ g 

and data. The input/output port 207 communicates w, * 3 ^^^.sy^etric RSA or the like. Many of IC 
device for executing modular calculated ,s used J^^STSSponJL of the IC card, 
card processors have no co-processor. A d*a bu > 203 "^Jl Memory), a RAM (Random Access Memory), an 
[0005] The storage memory 204 .ncludes a I ROM ^(Read uniy ™ w. whose contents 

EEPROM (Electrically Erasable Programmable ^<*5ftTE^^<^ can be rewritten freely and 
cannot be rewritten freely and stores mady programs. WM»* ^Sictad from the reader-write, a supply of the 
are erased if a power supply is intercepted Whence IC °Stt5M is a memory wh0S6 C0nt6ntS ^ * 

power is intercepted so that the contents of R ™^^^£?^ is used for storing data which may be rewnt- 
retained even if a supply of the power ,s .ntercepted. ^^.^^ r . wr iter. For example, the number of prepa.d 
ten and can be retained even if the IC card, £^£££Z£ZZi» card is used and the contents thereof 

ar^ed^^ ic ^ chip to execute a cipher 

same as decryption of a ciphering algorithm. "^^,^2^23^3^ a consumption current while the 
suming the contents of a cipher process and a aphe '^Vj^m a * 9 current can be monjtored by 
cipher process is executed, easier than ^^J^Z^ST^* is described in "Smart Card Handbook", by 
35 measuring the current supplied from the ^ ^2Sv e protective mechanisms, at p. 263. 

\£l%^22tt^^SZ^'>^~ ocardchpby 

40 monitoring the consumption current. f , c card cnip . Depending upon 

[0008] Fig. 5 shows wave shapes of consume ^ current f^™* 5 Y 01 and 502 . jhis difference is generated 

that of the central processing unit 201 during a J^"°^ °j thare is any correlation between the number of operations 

^prr-n^^ 

L, of pr.stnT.ing a c*her * b, idan.^g ft. . «* from ^T^TSluw. «l W eaiue of Ms of tha 
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SUMMARY OF THE INVENTION 
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tion current is reduced, it becomes difficult to presume the operation of the IC card chip and a cipher key from the mon- 
itored wave shape of a consumption current. The invention pays attention to that a presumption of the operation and 
cipher key from the wave shape of a consumption current can be made difficult by randomizing the process sequence 
in an IC card chip and inserting a dummy process. 

5 [001 2] A tamper resistance device, typically an IC card, can be considered as an information processing equipment 
having a program storage unit for storing a program and a data storage unit for storing data and a central processing 
unit for executing a predetermined process in accordance with the program to process the data, the program including 
one or more data process units each having a process instruction for giving an execution instruction to the central 
processing unit. In this invention, as one method of reducing the dependency of consumption current of an IC chip upon 

io data process, normal input data and its bit inverted data are processed. By using the normal input data and its bit 
inverted data by the same instruction, the number of transitions of the data on a data bus, from "0" to "1 " or vice versa, 
can be made constant. The data transition on the data bus consumes large current. By making the number of transi- 
tions on the data bus constant, the number of current consumptions is made constant so that the dependency of con- 
sumption current upon data process can be reduced. 

75 [0013] As an alternative method of processing normal data and bit inverted data in the same manner, a routine of 
processing the bit inverted data by an instruction same as the normal instruction, if the same routine cannot process 
both the normal data and bit inverted data. Normal input data and bit inverted data are always generated for the data 
once processed in order to process the normal data and bit inverted data in the same manner. 

[001 4] As an alternative method of reducing the dependency of consumption current upon data process, if there are 
l repetitive processes as many as the number of data sets to be processed, the data is not processed in the predeter- 
mined order but the process order is changed randomly. Another method is to add a dummy process which does not 
influence the corresponding process of a program, so that what operation of the equipment is executed at which place 
cannot be known. A combination of dummy processes and random execution of repetitive processes is effective for 
reducing the dependency of consumption current upon data process. 
25 [001 5] Use of both the normal data and bit inverted data and a combination of dummy processes and random exe- 
cution of repetitive processes is particularly effective for reducing the dependency of consumption current upon data 
process during a data permutation process and data substitution process on a byte-unit basis. 

[0016] Cryptosystems such as DES (data encryption standard) use many exclusive logical OR operations. There- 
fore, an exclusive logical OR unit for performing an exclusive logical OR of input data and cipher key data and a bit 

30 inverted exclusive logical OR unit for performing an exclusive logical OR of bit inverted input data and cipher key data, 
are effective for reducing the dependency of consumption current upon data process. A nonlinear substitution process 
unit for nonlinearly substituting input data and generating a substitution result and bit inverted substitution result and a 
nonlinear substitution process unit for nonlinearly substituting input bit inverted data and generating a substitution result 
and bit inverted substitution result, are effective for reducing the dependency of consumption current upon data proc- 

35 ess. A nonlinear permutation process unit for nonlinearly permuting input data and generating a permutation result and 
bit inverted permutation result and a nonlinear permutation process unit for nonlinearly permuting input bit inverted data 
and generating a permutation result and bit inverted permutation result, are effective for reducing the dependency of 
consumption current upon data process. 

[001 7] A combination of: the nonlinear substitution process unit for nonlinearly substituting input data and generat- 

^ ing a substitution result and bit inverted substitution result; the nonlinear substitution process unit for nonlinearly sub- 
stituting input bit inverted data and generating a substitution result and bit inverted substitution result; the nonlinear 
permutation process unit for nonlinearly permuting input data and generating a permutation result and bit inverted per- 
mutation result; and the nonlinear permutation process unit for non linearly permuting input bit inverted data and gen- 
erating a permutation result and bit inverted permutation result, is effective for reducing the dependency of consumption 

45 current upon data process. 

[0018] In the RSA cryptosystem utilizing a difficulty in prime factorization, a modular exponentiation calculation is 
performed by repeating a modular multiplication by using input data and a cipher key. One method of reducing the 
dependency of consumption current upon data process uses a modular multiplication process unit for performing a 
modular multiplication of input data multiplied by an intermediate modular calculation result irrespective of a value of 

so bits of the cipher key and a modular multiplication result selection unit for using a modular multiplication result by the 
modular multiplication process unit if the value of bits of the cipher key is 1, and neglecting the modular multiplication 
result by the modular multiplication process unit if the value if 0. It is therefore possible to perform a modular multiplica- 
tion irrespective of the value of bits of the cipher key. In this manner, the dependency of consumption current upon data 
process can be reduced, and it becomes difficult to presume the cipher key from the number of modular multiplication 

55 executions. 

[0019] The performance of RSA can be improved by using a modular exponentiation process unit for performing a 
modular exponentiation of input data in correspondence with each value of a plurality of bits and a modular multiplica- 
tion process unit for performing a modular multiplication of the modular exponentiation result by the modular exponen- 



OCID: <EP 1006492A1_I_> 



EP 1 006 492 A1 

•ion process unit multiplied by an intermediate modular calculation result. With this method, however, a pair of 
jdular exponentiation results is always used so that there is a possibility of presuming the cipher key from the depend- 
icy of consumption current upon data process. One method of solving this is to use a modular exponential result 
han^e process unit for changing the modular exponentiation result at a timing while the modular multiplication process 
nit processes to change the modular exponentiation result at a constant cycle pitch. With this method, although it 
jepends upon the change method, there is a case in which the modular exponentiation result is required to be changed 
»o tne original value. As one method for this, an inverse process unit is used for recovering the modular exponentiation 
^sult before the result is changed by the modular exponentiation process result change process unit. The inverse proc- 
ess unit can be realized by several method. One method is to add an integer multiple of a modulus of a modular calcu- 
lation to the modular exponentiation result. In an another method, the modular exponentiation result change process 
unit performs a modular exponentiation of the modular exponentiation result multiplied by v or v raised to a certain 
power among two values u and v whose molecular multiplication by using the modulus in the modular calculation is 1 
and the inverse process unit performs a modular exponentiation of u raised to the power whose order corresponds to 
the number of times during the modular multiplication through multiplication by v. One method of calculating the values 

15 v and u is to make the modular exponentiation result change process unit use two values 2 and (N + 1 )/2 whose molec- 
ular multiplication by using the modulus N in the modular calculation is 1. For the RSA cryptosystem, if the modular 
exponentiation process unit performs a modular exponentiation of input data raised to a certain power corresponding 
to each of all combinations of M bits of 0 and 1 of the cipher key; if the modular exponentiation result change process 
unit executes at a certain timing a modular exponentiation of the modular exponentiation result multiplied by v or v 

30 raised to a certain power among two values u and v whose molecular multiplication by using the modulus N in the mod- 
ular calculation is 1 ; if the modular multiplication process unit performs a modular multiplication of a modular exponen- 
tiation result by the modular exponentiation process unit multiplied by an intermediate modular multiplication result in 
correspondence to each of the value of the M bits of the cipher key; and if the inverse process unit performs a modular 
exponentiation of u raised to the power whose order corresponds to the number of times during the modular multiplica- 

25 tion through multiplication by v, then the dependency of consumption current upon data process can be reduced effec- 
tively. In this case, the values v and u can be obtained easily if the modular exponentiation result change process unit 
executes at a certain timing a modular exponentiation of the modular exponentiation result multiplied by v which takes 
an arbitrary binary power by using the modulus N in the modular calculation, and if the inverse process unit performs a 
modular exponentiation of (n + 1)/2 raised to the power whose order corresponds to the number of times during the 

30 modular multiplication through multiplication by 2. 

BRIEF DESCRIPTION OF THE DRAWINGS 
[0020] 

35 

Fig. 1 shows the hardware structure of an IC card. 
Fig. 2 shows the hardware structure of an IC card chip. 
Fig. 3 shows an overall process flow of DES. 
Fig. 4 shows a process flow of an f-function of DES. 
40 Fig. 5 shows wave shapes of consumption current. 

Fig. 6 shows the structures of normal data and bit inverted data. 

Fig. 7 is a flow chart illustrating an exclusive logical OR of a cipher key and a selectable permutation result. 
Fig. 8 illustrates a routine of first processing E normal permutation sub-data. 
Fig. 9 illustrates a routine of first processing E bit inverted permutation sub-data. 
45 Fig. 10 illustrates an S box process. 

Fig. 1 1 illustrates a routine of first processing an execution result of a normal exclusive logical OR. 
Fig. 12 illustrates a routine of first processing an execution result of bit inverted exclusive logical OR. 
Fig. 13 illustrates a P permutation process. 

Fig. 1 4 illustrates a routine of f irst processing normal S box process data. 
so Fig. 1 5 illustrates a routine of first processing bit inverted S box process data. 
Fig. 16 shows a P permutation matrix. 

Fig. 17 illustrates a routine of an S box conversion process using an S box table. 
Fig. 18 illustrates a process routine of RSA. 

Fig. 19 illustrates a process routine of RSA in which a modular multiplication process is performed independently 
55 from the value of bit of a cipher key 

Fig. 20 illustrates a routine of RSA on the two-bit process basis. 

Fig. 21 illustrates a process routine of RSA wherein a modular exponentiation result of input data corresponding to 
bits is changed by adding an integer multiple of the modulus of a modular calculation. 
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Fig. 22 illustrates a process routine of RSA wherein an inverse process for changing a modular exponentiation 
result of input data corresponding to bits is executed last. 

Fig. 23 illustrates a process routine of RSA wherein the inverse process for changing a modular exponentiation 

result of input data corresponding to bits is executed at an intermediate stage. 
5 Fig. 24 illustrates a selectable permutation process. 

Fig. 25 illustrates a routine of first processing normal input data. 

Fig. 26 illustrates a routine of first processing normal input data. 

Fig. 27 shows an E selectable permutation table. 

Fig. 28 illustrates a call of a data process routine by using addresses. 
w Fig. 29 shows an S box table. 

Fig. 30 shows an extended S box table. 

Fig. 31 illustrates a process sequence of modifying a modulus in a modular calculation. 
DETAILED DESCRIPTION OF THE EMBODIMENTS 

15 

[0021 ] Embodiments of the invention will be described with reference to the accompanying drawings. 

[0022] Fig. 1 is a plain view of an IC card. The position of an IC card chip 1 02 and the number of contacts and their 

assignments of the IC card 101 are defined by ISO 7816 specifications. 

[0023] Fig. 2 shows the internal structure of the IC card chip 102. The structure has been described already with 
* respect to conventional techniques. According to this invention, a program 205 is not executed always in the same man- 
ner, but it is executed randomly or a dummy process is added in order to reproduce the wave shape of a current to be 
consumed by hardware of the IC card chip. 

[0024] In this embodiment, although symmetric DES and anti-symmetric RSA are used by way of example, the 
embodiment may be applied to other cryptosystems. Cryptosystems such as DES and RSA are described, for example. 

25 in "Introduction of Cryptography Theory" by Eiji Okamoto, KYOURITSU Publication Co. 

[0025] DES performs encryption and decryption of 64-bit data (plain text and cipher text) by using a cipher key of 
56-bits. Since the same cipher key is used for encryption and decryption, DES is called a symmetric cryptography. As 
trump cards are turned randomly bits of a plain text (to be enciphered) are randomly exchanged and enciphered. Data 
exchange is performed in accordance with the cipher key. When data is deciphered, bits of a cipher text are exchanged 

30 in the reverse order of the enciphering to recover the original data. Data exchange of DES uses two exchange methods 
one being a one-bit unit basis and the other being a plural-bit unit basis. The former is called permutation and the latter 
called substitution. 

[0026] Referring to Fig. 3, DES cryptography will be described. A cipher text is subjected first to initial permutation 
(IP) 301 . This permutation is performed by using an initial permutation table to exchange 64-bit data of the cipher text 
35 on the one-bit unit basis. A series of such operations is repeated sixteen stages to inverse permutation (IP" 1 ) 313 of the 
initial permutation. 

[0027] At each stage, a process called a f function 303 is calculated by inputting data of 32 bits of either the first or 
second half at the preceding stage and the cipher key, and then an exclusive logical OR operation 305 is performed by 
using the output of the f function and 32 bits of the remaining half at the preceding state. Data of the cipher key is also 
4.. _ exchanged. Data of the cipher key is first subjected to selectable permutation PC-1 (302) by using a table PC-1 . There- 
after, data of the cipher key is subjected to selectable permutation PC-2 (304) by using a table PC-2. At the next stage, 
each set of 28 bits of the cipher key rounded in accordance with an RS table is used. 

[0028] The process by the f function is illustrated in Fig. 4. Data input to the f function is subjected to selectable per- 
mutation by using an E selectable permutation matrix (402). Next, an exclusive logical OR is calculated between the 

45 cipher key and a result of the selectable permutation for the input data (403), an S box process is executed (404), and 
a P permutation process is executed (405). In the S box process, each 6-bit set is extracted from 48 bits which is a result 
of the exclusive logical OR at 403, to acquire the row and column numbers of an S box table and generate 4-bit data. 
The contents of the S box table change with the position of each 6-bit set. The P permutation process exchanges the 
bit positions of 32 bits by using a P permutation table. 

so [0029] If the process sequence is the same, a shift in the wave shape of the consumption current changes depend- 
ing upon data. Therefore, according to the invention, a process randomly changing its sequence at each execution 
cycle is added to each process shown in Fig. 4. 

[0030] With reference to Fig. 24, the selectable permutation process 402 will be described. The selectable permu- 
tation process exchanges the bit positions of data input to the f function by using the E selectable permutation matrix E 
55 and expands the input data of 32 bits to 48 bits. The E selectable permutation matrix (2701) is shown in Fig. 27. The 
32-nd, 1-st, 2-nd, .... 32-nd and 1-st bits of the input data as counted from the upper left (2702) to the lower right (2702) 
are used as 1 -st to 48-th output bits. 

[0031 ] Prior to describing the selectable permutation process, data to be used for the selectable permutation proc- 
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ess of this embodiment will be described. As shown in Fig. 6, data is input to the f function as a combination of normal 
data 602 at the preceding stage and its bit inverted data 603. By inputting such a combmaton of data h^mber of 
•■0" bits and the number of "1" bits are always the same. For example, if the Ms of normal data ,s 001 11 MWO .JN > bris 
of its bit inverted data becomes "1 100001 1". The number of "0" bits of the comb.nat.on of > nomnridaft a nd rtjbrt 
inverted data is "8" and the number of "1 " bits is also "8". i.e., Hamming we.ghts are the same 8 . Therefore, if the com- 
£££ o^e norm* data and its brt inverted data is transferred to the data bus 203. the dependency of consumpt.cn 
currln? d*a process will no. appear because the numbers of bits "0" and "1 » are always the same. For examp^ 
if the data bus 203 is a precharge bus, as a preparation for data transfer, the values on the data bus are once changed 
a to »1^4nd7hereafter data is transferred. In this case, since the values on the data bus are all the same in the 
p echarged state, the numbers of bits changing from "1 " to "0" and from "0" to "1 " are always the same during precharg- 
Tng if the combination of the norma, data and its bit inverted data is transferred. Therefore, the dependency ^fcon- 
sumption current upon data process is reduced. If the data bus is a static bus provd.ng no P^*^ 
of each bit is dependent upon the values of preceding data. However, s.nce the Hamm.ng we.ghts of transferred date 
are always the same, the dependency of current consumption upon transferred data ,s small. If the normal data only .s 
transferred, the Hamming weights are not a.ways the same so that the consumption ^*P«*"^^ " * 
making the Hamming weights constant by transferring a comb.nat.on of normal data and rts bit .nverted data, the 
dependency of consumption current upon transferred data reduces. 

[0032] The procedure of the selectable permutation is illustrated in Fig. 24. ^ ^ nt 

0033 The selectable permutation process processes input 32-bit data on a 6-bit unit bas.s and genera esdata erf 
48 bits. The data to be processed includes input normal data and its bit inverted data, and ,s co nstrtuted of two bytes 
each having 8 brts. The selectable permutation process is generally executed in the arrangement order of heEs^ 
ble permutation matrix. However, in this case, since the data process order « always constant, data .to be >P^»ed 
may be presumed. In this embodiment, therefore, the execution order is random.zed and a dummy process :m Wed 
randomly so as not to make the execution order constant. With a randomized execut.on order, the dependency of con- 
25 sumption current upon data process can be reduced. ..^j/oimi Thieemni- 

[0034] In the selectable permutation process of this embodiment, execut.on flags are cleared (2402) This execu 
Kg takesa value "V if a corresponding bit in each process repetition unit hasbeen processed completely, whereas 
Uake a value "0" if it is not still processed. If all bits of the execution flags are "1 ". the process is terminated, whereas 
S the process conLes to acquire a random number (2404). If the IC card chip has a random number genua* 
so he random number may be supplied from the generator. Alternatively, a pseudo random number may be gene ated in 
Ts^^^n^on of Cryptography Theory" by EH Okamoto. KYOUR.TSU Publishing Co., at pp. 61 

[0035] In order to determine which process is executed in each process repetition unit, an execution index is 
decided by using a random number (2405). For example, if the E selectable permutat.cn matr.x is processed one row 
35 after another, the execution index is given by the following formula (1): 

Execution index = (random number AND 0x07) % 8 0) 

The lower 3 bits of the random number are extracted through an AND product with 0x07 and divided t >y 8 ■Thun- 
der is used as the row to be processed. If the E selectable permutation matnx ,s processed one b.t after another, the 
execution index is given by the following formula (2) : 

Execution index = (random number AND 0x01 F) % 32 (2) 

The lower 5 bits of the random number are extracted and divided by 32. The remainder is used as the ^umber erf ^.e bit 
to be processed. Since the execution index is decided by the random number only, the execut.on order becomes ran- 
dom and the already processed data is selected in some cases. In this embodiment, such features are pos.t,vely incor- 
porated in order to reduce the dependence of the wave shape of consumption current upon data process. 
Em Next, the execution flag conesponding to a bit processed is set to "1 « (2406). One ^"^SSS 
s the following method. Namely, in the following formula (3). the execution .ndex corresponding to the processed bit is 
Lei to "1^ in the following formula (4). an exclusive .ogioal OR between the execution index and execut.on flag is 
calculated to set the execution flag of the processed bit to "1 

K = 1 is left-shifted by an amount corresponding to the execution index (3) 
Execution flag = execution flag XOR K ( 4 ) 
With the above processes, the process repetition unit is selected randomly by using a random number so that the order 
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of process repetition units does not become constant. 

[0037] Accordingly, the dependency of consumption current upon data process does not appear and a presumption 
of data process and cipher key becomes difficult. Since the process repetition unit is selected and executed randomly, 
there is a possibility that the same process is executed twice or more. This makes the process time indefinite so that a 

5 presumption of the dependency of consumption current upon data process becomes more difficult. 

[0038] Next, each process in the process repetition unit selected by the execution index will be described. Each 
process corresponds to each row process or each bit process for the E selectable permutation matrix. First, in accord- 
ance with the execution index, input normal data and its bit inverted data are acquired (2407). In this embodiment, a 
similar selectable permutation process is executed for both the input normal data and its bit inverted data. In this case, 

70 in order not to process the input normal data and its bit inverted data always in the same order, the execution order is 
randomized. To this end, a random number is acquired (2408) to calculate an address difference (2409). In accordance 
with this address difference, an address of a called routine is calculated (2410) and the routine is called (241 1). 
[0039] An embodiment of calling a data process routine by using the address difference will be described with ref- 
erence to Fig. 28. An address 2802 of a routine to process the input normal data at first and an address 2803 of a rou- 

75 tine to process the bit inverted data at first are stored in a memory 2801. A difference between two addresses is the 
address difference described above. Assuming that the address storage unit is two bytes, one method of calculating the 
address different (2409) is as follows. 

Address difference = (random number AND 0x01) * 2 (5) 

The least significant bit of a random number is multiplied by 2. The address to be used for calling the routine is obtained 
by adding the address difference to the base address 2802 of the data area where the selectable permutation routine 
is written. In this example, as the base address, the address 2802 of the routine to process the normal data at first is 
written, and the address 2803 of the routine to process the input bit inverted data at first is written at an address of the 

25 base address + 2 bytes If the least significant bit of the random number is "0", the address difference is 0 so that the 
address 2802 of the routine to process the input normal data at first is selected and the routine 2804 to process the 
input normal data at first »s caMec if the least significant bit of the random number is "1", the address difference is 2 so 
that the address 2803 of the routine to process the input bit inverted data at first is selected and the routine 2805 to 
process the input normal data at first is called. 

30 [0040] Since the address difference is calculated by using the random number, the routine to process the input nor- 
mal data atfirst and the routine to process the input bit inverted data atfirst are randomly selected and the input normal 
data and input bit inverted data are not always processed in the same order. Accordingly, the dependency of consump- 
tion current upon the input normal and bit inverted data process can be reduced. 

[0041 ] As shown in Fig 25. m the routine to process the input normal data atfirst, the input normal data is subjected 
35 to a selectable permutation (2502). and then the input bit inverted data is subjected to a selectable permutation (2503). 
As shown in Fig. 26, in the routine to process the input bit inverted data at first, the input bit inverted data is subjected 
to a selectable permutation (2602). and then the input normal data is subjected to a selectable permutation (2603). A 
routine 2806 to execute an actual selectable permutation is called from the corresponding routine to execute a selecta- 
ble permutation of bits. The selectable permutation (2503 or 2602) for the input bit inverted data generates data by 
inverting bits of the result of the selectable permutation of the normal data. The reason for this is that since the selecta- 
ble permutation is the permutation of bit positions, a bit inversion relation between the normal data and bit inverted data 
can be retained. The normal data and bit inverted data are stored as a combination as shown in Fig. 6 so that the 
dependency of consumption current upon transferred data can be reduced. 

[0042] With the above-described processes, each time one data process in the process repetition unit is com- 
45 pleted, the flow returns to (2403) If all the data is still not processed, data to be processed is randomly selected by 
using a random number to repeat the data process. Since data to be processed is selected by using only random num- 
bers, the same data is processed in some cases. Even if the same data is processed twice or more, the selectable per- 
mutation poses no problem. 

[0043] As described above, the input normal data and input bit inverted data used by the selectable permutation of 
so this embodiment are an example of a "combination of normal data and its bit inverted data". The routine to process input 
normal data at first illustrated in Fig. 25 and the routine to process input bit inverted data at first illustrated in Fig. 26 
have a normal data process sequence and a bit inverted data process sequence which sequences are an example of 
a "normal data instruction and brt inverted data instruction process unit". The routine to process input normal data at 
first illustrated in Fig. 25 and the routine to process input bit inverted data at first illustrated in Fig. 26 generate a result 
55 of selectable permutation of the input normal data and a result of bit inverted normal data, which are an example of a 
"bit inverted data generation unit. The data process routine 2806 executes the selectable permutation process both for 
the normal data and its bit inverted data, which is an example of a "normal data and bit inverted data process unit". 
Steps (2402 to 2405) for randomly changing the process order by using execution flags and random numbers are an 
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example of a "repetitive random execution process unit". Steps (2402 to 2406) for randomly processing twice or more 
the data already processed by using execution flags and random numbers are an example of a dummy ex^t on proc- 
ess unit" Steps 2402 to 2406 using execution flags and random numbers realize both adummy process and a repetitive 
random process at the same time, which are an example of a "dummy execution and repetitive randonr execution proc- 
ess unit" A process described with selectable permutation shown in Fig. 24 is a typ.cal example of a brt unrt permuta- 
tion process unit". 

[0044] Next, an example of the exclusive logical OR process between input data subjected to selectable permuta- 
ionand the cipher key wfll be described. The basic sequence of this process is almost equal to the sequence of the 
selectable permutation process already described with reference to Fig. 24. A ma.n different point is that the cal 
address at ?710) is calculated basing upon the base address of an exclusive logical OR routine This exclusive logical 
OR process processes two data sets generated by the selectable permutation process. One data set is normal E per- 
mutation data obtained through selectable permutation of input normal data, and the ottner data set » b Unver ed E per- 
mutation data obtained through selectable permutation of input bit inverted data. These data sets are stored in the 
format shown in Fig. 6, and read at the same time as a pair of normal data and bit inverted data. The bit inverted E per- 
mutation data is bit inverted data of the normal E permutation data. The normal E permutat.on data and cpher key bo* 
have 48 bits. Since the next S box process is a process to be executed in the unit of 6 bits, the exclude logical OR 
process is executed often on the 6-bit unit basis. The exclusive logical OR process may be executed or , thel-brt .art 
basis, in the former case, the processes (703 to 71 1) are required to be repeated at least 8 times, and in the latter case, 
the processes (703 to 711) are required to be repeated at least 48 times. 

[0045] In a routine to process normal E permutation sub data at first, an exclusive logical OR operation .s first exe- 
cuted between the normal E permutation sub data and a cipher sub key (802). and then an exclusive logical OR oper- 
ation is executed between the bit inverted E permutation sub data and the cipher sub key (803). This execution order is 
reversed for a routine to process bit inverted E permutation sub data at first (902 and 903). 

[0046] A result of the exclusive logical OR of the normal E permutation sub data and cipher sub key has a bit inver- 
sion relation to a result of the exclusive logical OR of the bit inverted E permutation sub data and cpher sub key The 
is because the bit inversion relation is retained through the exclusive logical OR operations between the normal data 
and bit inverted data and the same cipher sub key. 

[00471 The routine to process the normal E permutation sub data at first (801) and the routine to process the bit 
inverted E permutation sub data at first (901) perform the exclusive logical OR operation between normal data and 
cipher key data and the exclusive logical OR operation between the bit inverted data and cipher key data, which are 
examples of an "exclusive logical OR process unit" and a "bit inverted data exclusive log.ca OR process un.K 
[0048] Next the S box process (404) will be described. The fundamental sequence of the S box process of this 
embodiment is similar to the sequence of the selectable permutation process shown in Fig. 24 
T00491 First in order to randomize the start of the S box process, a random number is acquired (1002) to execute 
a dummy process in accordance with the random number (1 003). This dummy process may be a l proces ^ gating 
a loop wrthout a loop process as many times as the value of the random number. Since the number of loop operations 
changeTwHh the random number, the start of the S box process becomes random so that the dependency of the wave 
shape of consumption current upon data process reduces. 

rO0501 Steps (1004 to 1013) of randomizing the process order by using execution flags and random numbers and 
adding a dummy process are similar to steps 2402 to 241 1 of the selective permutation process. The S box £00868 >* 
executed by using an execution result of the exclusive logical OR between the E permutation data and cipher key. An 
execution result of the exclusive logical OR process (403) between the cipher key and the execution result of the selec- 
tive permutation are the data containing a pair of normal data and bit inverted data such as shown in Fig. 6. When an 
execution result of the exclusive logical OR between data indicated at the execution index is acquired, a pair of data is 
acquired in the manner similar to the process described earlier. A routine (1 101) to process an execution result of the 
normal exclusive logical OR at first and a routine (1201) to process an execution result of the bit inverted exclusive log- 
ical OR at first are randomly called by using random numbers. 
0051 ] in the S box process, an address of the S box table is calculated for each set of six bits of ih. ««^«* 
of an exclusive logical OR (1 702), to obtain 4-bit data which is a result of the conversion result by the S box (1 703) In 
so calculating the address, a row number is calculated from two bits of the first and second bits of the input 6 b.ts, and the 
column number is calculated from four bits of the second to fifth bits. 

[0052] There are eight S box tables. Each S box table is used for the converse of 6 b.ts which are a result of the 
exclusive logical OR. In a general first S box table 2901 , the first to fourth columns and the first to fourth rows have data 
such as shown in Fig. 29. In this embodiment, as shown in Fig. 30. the S box table is expanded so as to obta.r , also » bit 
55 inverted data. Although the display range of the S box table shown in Fig. 30 is the same as that shown in R* 29 each 
element of the S box table shown in Fig. 30 is expanded to two fields. The first field (left field, e.g. a Md 3004 stores 
data in the corresponding element of the S box table shown in Fig. 29, and the second field (right field, e.g., a field 3005) 
stores bit inverted data in the first field. 
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[0053] In the routine (1 101) to process the execution result of the normal exclusive logical OR, normal S box proc- 
ess data and bit inverted S box process data are obtained from the execution result of the normal exclusive logical OR 
by using the expanded S box table (1 102). Next, normal S box process data and bit inverted S box process data are 
obtained from the execution result of the bit inverted exclusive logical OR by using the expanded S box table (1103). 

5 Since the S box process is executed by using the execution result of the bit inverted exclusive logical OR, the result of 
the process (1 1 03) is not used. However, in order to reduce the dependency of consumption current upon data process, 
it is executed as a dummy process. The execution order of the above processes is revered in the routine (1 201 ) to proc- 
ess the execution result of the bit inverted exclusive logical OR, and similarly the result of the bit inverted exclusive log- 
ical OR, i.e., normal S box process data and bit inverted S box process data, are not used. Data to be passed to the 

70 next P permutation process is the execution result of the normal exclusive logical OR, i.e., the normal S box process 
data and bit inverted S box process data. 

[0054] In order to obtain the normal S box process data and bit inverted S box process data from the execution 
results of the exclusive logical OR by using the expanded S box table, an address of the S box table is first calculated 
from 6 bits which are the execution result of the exclusive logical OR (1702). Next, the normal S box process data is 
75 obtained from the first field of the expanded S box table (3001) and the bit inverted S box process data is obtained from 
the second field (1703). 

[0055] The normal S box process data and bit inverted S box process data obtained during the S box process are 
an example of the "combination of normal data and its bit inverted data". The process (1 703) of acquiring the normal S 
box process data and bit inverted S box process data by using the expanded S box table 3001 is an example of the "bit 
inverted data generation unit. The processes (1 103 and 1202) of obtaining the S box conversion result from the execu- 
tion result of the bit inverted exclusive OR, i.e., the normal S box process data and bit inverted process data, by using 
the S box table, process not the normal data but the bit inverted data so that both the normal data and bit inverted data 
can be processed in the similar manner and the dependency of consumption current upon data process can be 
reduced. These processes are an example of the "normal data instruction and bit inverted data instruction process 

25 unit". The S box process is an example of a substitution process in the unit of 6 bits and not in the unit of 1 bit. The rou- 
tine (1 101) to process the execution result of the normal exclusive logical OR at first or the routine (1201) to process 
the execution result of the bit inverted exclusive logical OR at first are an example of a process of substituting the normal 
data, obtaining the substitution result and bit inverted data, substituting the bit inverted data, and obtaining the substi- 
tution result and bit inverted data. 

30 [0056] The P permutation process (405) will be described with reference to Fig. 13. The P permutation process is 
similar to the selectable permutation process (2401 ). The different point is a use of a P permutation matrix 1 601 shown 
in Fig. 16. 

[0057] The normal S box process data and bit inverted S box process data in the format shown in Fig. 6 are sup- 
plied as the execution result of the S box process. In a routine (1401) to process the normal S box data at first, P per- 
35 mutation is executed for the normal S box process data (1402), and then P permutation is executed for the bit inverted 
S box process data (1403). The execution order of these processes is reversed for a routine (1501) to process the 
inverted bit S box data at first. Since the P permutation exchanges the bit positions, the bit inverted P permutation proc- 
ess data as the process result of the bit inverted S box process data has a bit inversion relation to the normal P permu- 
tation process data as the process result of the normal S box process data. 

[0058] Examples of the f function processes (402 to 405) have been described above. In this embodiment, the 
order of data processes is randomized, a dummy process is added, and the normal data and bit inverted data are used. 
It is therefore possible to make it difficult to presume the dependency of current consumed by the IC card chip upon 
data process and to presume the cipher key by measuring the wave shape of the consumption current. 
[0059] Next, an embodiment for RSA will be described. RSA is a cryptographic algorithm utilizing a difficulty in 
45 prime factoring. Since different keys are used for enciphering and deciphering, this algorithm is called an anti-symmet- 
ric algorithm. For both the enciphering and deciphering, the following modular exponentiation calculation is used. 

y = x ** e mod n (6) 

so [0060] An equation "a = b mod n " means that (a - b) can be divided out by n. In the deciphering, x represents a 
cipher text, e represents a secret key, and y represents a deciphered plain text. The modular exponentiation calculation 
can be made by using modular multiplications. Some IC cards have a co-processor capable of calculating modular mul- 
tiplication in order to calculate modular exponentiation at high speed. A modular multiplication is given by: 

55 y = a * b mod n (7) 

[0061] A method of calculating modular exponentiation by using modular multiplication is illustrated in Fig. 18. This 
calculation method is described, for example, in "Introduction of Cryptography Theory", by Eiji Okamoto, KYOURITSU 
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Publication Co.. at page 94. A binary expansion of an integer of the secret key e is given by e = e0, el, e2, .... e(w -1). 
The binary expansion results (hereinafter called bits of e) are a binary bit train representing e. The value y .s mAabzed 
to "1" (1802), a modular second power calculation of y raised to the second power is performed us.ng a modulus £ 
starting from the most significant bit of e (1805), and if the value of the corresponding bit is 1 ^ 
power calculation of y multiplied by x is performed using the modulus n (1 807). If the value of each bit is 0 . the process 
(1807) is skipped The processes (1 805 to 1807) are repeated from the most significant bit to the least s.gnrf.cant bit. 
[0062] In the process sequence shown in Fig. 18, if the bit of e is "1", the co-processor operates twice . whereas i rf 
the bit of e is "0", it operates only once. The secret key e can therefore be estimated by monitoring the operation of the 
co-processor If the number of operations of the co-processor is made the same irrespective of the positions of b.ts of 
binary expansion of e, it becomes difficult to presume the secret key by monitoring the operation of the co-processor. 
m0631 Fig 1 9 illustrates the process sequence of modular exponentiation capable of making difficult to presume a 
secret key by using the same number of operations of a co-processor for each bit. In this embodim enUrrespect .ve of 
the values-of bits of the secret key e, a modular first power multiplication of y multiplied by x is performed (1906). If the 
value of bit of e is "T. the calculation result is substituted to y (1908), whereas if not, the calculation result of y is used 
as it is (1909) The p.ocess is repeated to reach the least significant bit. In this embodiment, since the number of oper- 
ations of the co-p-ocessor is the same irrespective of the value of bit of e, the values of bits of the secret key e cannot 
be identified even .f the operation of the co-processor is monitored from the wave shape of consumption current. A mod- 
ular multiplication unit .s realized by the process (1906) and a modular multiplication process result selection unrt 1907 

is realized by the processed (1907 to 1909). . « > «—«-j 

r00641 A method of calculating the modular exponentiation calculation shown in F,g. 19 at high speed .s illustrated 
n Fig 20 This method ufl.zes a method called an addition chain method described in "Introduction of Cryptography 
Theory" by Eiji Okamoto. KYOURITSU Publication Co., at page 95. The method illustrated in Fig 19 processes data .n 
the unit of one bit of e, whereas the method illustrated in Fig. 20 processes data in the unit of a plurality -of brts of ft The 
method shown in Fig 20 processes data in the unit of 2 bits. First, the cipher texts x raised to the 0-th. 1 -St. 2-nd and 
3-rd powers are calculated (2002) Next y ,s initialized to "1 " (2003). If the last bit is not still processed (2004). the quad- 
ratic residue calculation is executed tw.ce Th,s operations correspond to shifting the value y to the uppe t digits by two 
bits, in accordance with the uppe, two bus of e. the processes (2010 to 2013) are selectively performed espe^ for 
the values of upper two bits of W '01 "10" and "1 1 ". In each process, a modular first power multiplication of y storing 
the intermediate modular muitd.cat.or result and multiplied by a corresponding value of t[0] to t[3] is executed I in 
accordance with each value of two b.«s of e. For example, the process (2012) ,s executed for the value 10 of two bfe 
of e and y is multiplied by t(2] wn,cn stores the quadratic residue of x. Until the last b.t is processed the processes 
?2004) to (2013) are repeated If the <ast two bits of e contain only one bit, the method illustrated in F,g. 18 or 19 .s per- 

looesf m the method shown .n F,g 20. irrespective of which value the two bits of e have, the ^-processor operates 
Lice at the process (2005) and once at one of the processes (2010 to 2013), three t.mes ,n total. It ,s therefore drif, cult 
to presume the bits of e by s.mp.y mon.tor.ng the operation of the co-processor. In the method shown in Fig. 19 the ^co- 
processor operates twice to process one b.t. whereas in the method shown in Fig. 20 the <?*<^ <*«"»^ 
times to process two bits, i.e.. 1 5 t.mes per one bit. Therefore, the two-bit method shown ,n F.g. 20 ,s faster about 25 
% than the one-bit method shown ,n F.g. 19. The reason why the process time is proportional to the number of opera- 
tions of the co-processor, is because the processes shown in Figs. 20 and 19 require the co-processor operation to take 

a iarqe portion of the process time * _ 

[0066] However, the same values of t[0] to t[3] are used at each of the processes (2010 to 2013) to process the two 
bits of e. Therefore, there is a poss.b.l.ty of presuming the bits of e if the dependency of the wave shape of consumption 

current upon data process appears 

[0067] In this invention, the values of t[0] to t[3] are changed at the intermediate stage of the modular exponentia- 
tion to reduce the dependency of the wave shape of consumption current upon data process. An embodiment of this 
will be described with reference to F.g. 21. A different point of the method shown in Fig. 21 from that shown .n F.g. 20 
• is an addition of processes (2105 and 2106). In the embodiment shown in Fig. 21 . dur.ng the repetitive processes of the 
modular exponentiation of two b.ts of e. the values to t[i] are changed each time the number °^ e P e «'° ( ns Jf ache ^ 
certain fixed number. In the process (2105), it is checked whether the number of repetitions reaches the 
and if reaches, the values of t[i] are changed. The fixed number at the process (2105) may be the value obtained by 
dividing the number of digits of e by "20". Since the 2-bit method is used, this means the values of t[.] are changed 110 
times. The values of t[i] may be changed when an arbitrary digit or lower digits are processed. There are many ^methods 
of changing the values of tOJ. The feature of the invention resides in changing the values of tp] during repetitive proc- 
esses during the modular exponentiation. In the process (2106). each value of ffl is changed by adding a va ue 
obtained by multiplying the modulus n of modular calculation by a random number. Th.s can be realized as in the fol- 
lowing. 
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x = random number (8) 

t[i]=t[i] + r*n (9) 

[0068] In the corresponding one of the processes (2112 to 21 15), the modular multiplication of y multiplied by the 
changed t[i] is executed using the modulus n as in the following. 



y = y*t[i]modn (10) 
= y * (t[i] + r * n) mod n 
= y * tnj mod n + r * n mod n 
= y * t[i] mod n 



[0069] As seen from this equation, the term (r * n) is eliminated because (r * n mod n ) is zero, i.e., (r * n) can be 
divided out by n. Since the values of t[i] used by the processes (21 12 to 2115) are changed each time the fixed number 

75 of repetitive processes is executed, the dependency of consumption current upon data process can be reduced. The 
process (2102) corresponds to a "modular exponentiation calculation process unit" for input data corresponding to a bit 
value, and the processes (2108 to 21 15) correspond to a "modular multiplication calculation unit" of input data corre- 
sponding to each bit. The processes (2105 and 2106) are realized by a "modular exponentiation change process unit" 
for input data corresponding to a bit value. A "modular exponentiation value change process unit" for input data corre- 
sponding to a bit value in which an integer multiple of the modulus of the modular calculation is added to the modular 
exponentiation value of input data corresponding to the bit value, is realized by the process (2106). 
[0070] As another example of the "modular exponentiation change process unit" for input data corresponding to a 
bit value, there is a method of using "2" raised to an arbitrary power r as the value to be multiplied by the modulus of the 
modular calculation. By using "2" raised by the power r, a calculation of multiplying the modulus by "2" raised to the 

25 power r can be made easy Multiplying the modulus N by "2" raised to the power r is equivalent to shifting the modulus 
N by r bits to the left. Generally, since the modulus takes an integer of 100 bits to 1 000 bits, it takes a long process time 
to multiply the modulus N by a random number r. A shift operation is much faster than multiplication. If a multiplication 
of 2 raised to the 8-th power is used instead of a multiplication of 2, the 8-bit shift or one-byte shift is used instead of 
one-bit shift and can be performed at higher speed. This is because the left shift by one byte corresponds to moving the 

30 data by one byte to the left, and can be realized by a data move instruction not by a shift instruction. 

[0071] Another embodiment of the method of changing the values t[i] will be described with reference to Fig. 22. In 
the method shown in Fig. 22, the values of t[i] are changed by executing a modular exponentiation of t[i] multiplied by a 
certain value as in the following. 

35 t[i] = t[i] * v mod n (11) 

[0072] With this method, when the modular exponentiation is completed, an inverse number to a value of the mul- 
tiplied value of the modulus n is multiplied to obtain the original value. 

k = the number of times during modular exponentiation through multiplication by v (12) 

s = u**kmodn (13) 

y = y*smodn (14) 

45 

where u * v mod n = 1 (15) 

[0073] This method obtains the original value by multiplying u by the number of times during modular exponentia- 
tion through multiplication by v, as in the following. 

50 

y = y*v**kmodn (16) 
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y = y *u**kmodn * ^ 

= y*v**k*u**k mod n 
= y * (v * u) ** k mod n 
= y mod n * (v * u) ** k mod n 
= y mod n * ((v * u) mod n) ** k mod n 
= y mod n * 1 mod n 
5 = y mod n * 1 

= y mod n 

[0074] Since v is multiplied during modular exponentiation, y takes a value of m ^ ,a ^P° ne " tiafo "^ 
» multiplied by v by using the modulus k. y takes a value of modular exponentiation of y multiplied by u by us.ng the mod- 

modu us n v and its inverse u are obtained in a process 2204. In a process (2207). v .s modified so as not to use the 
S Tone methS of modifying v is to obtain a random number and perform a modular exponentiation of by -using 
he random number as the modulus. Another method is to increase the number of modular exponent,*, ons of v each 
me repetle Processes exceeds a certain fixed value. A modular multiplication ^^^S^^St J- 
exited (2208) If all bits of e are processed, a calculation of invalidating v is executed by using u to obtain correct val 
^eTo W2218) If is known in advance or a predetermined random number is used, s indicating the modular^ 
nation ^ multiplied by the number of times during multiplications by v can be calculated ,n advance. By using th* 
value s. the original values of y can be calculated as in the following. 

y = y * s mod n 

S^T^P^ SoZT^Ls are realized by a "modular exponentiation result <^~* 
or pertorming a modular exponentiation of the modular exponentiation result multiplied by v or v raised t , a ^certain 
power arZc "L values u and v whose molecular multiplication by using the modulus in the modular calculation ,s 1 . 

The Drocess 2218 is an example of an "inverse process unit". 

mm Next an example of the process to be executed by the inverse process unit at the ■ntermed'ate stagey of o*- 
E„ Ms?; not after the calculation of all bits of e will be described with reference to fig. 23. In Mttie proves 
snown in fig 23 processes (2307 to 2317) are the same as those processes (2207 to 221 7) shown in F,g. 2*A ^proc- 
esTSlS) conesponding to the process 2218 is executed after the process (2314 or 2317) For example, after the 
miSr 2ST2Sn o. ifi] muWpUed by v is executed, if this operation is to be canceled eaoh time, the following equa- 
tion is performed. 

y = y*umodn ( 19 ) 

[0078] This is because y multiplied by t[i] at the processes (2314 to 2317) equals to the original t[i] multiplied by v. 

t[i] = t[i] * v mod n ( 20 ) 

y =y*t[i]modn ( 21 * 
= y * t[i] * v mod n 

y = y + u mod n ( 22 ) 
= y * t[i] * v * u mod n 
= y * t[i] mod n 

[0079] in the process (2308), t[i] is modified as shown by the equation (20), and in the processes (2314 to ,2317) 
so Kuation (21) I calculated. By using this calculation result, the equation (22) is calculated ,n the process (2318) to 

determined cycle pitch. In this case, as the value u in the equation (1 9), the value representee of the number of mod- 
ifications by v is selected and the equation (19) is calculated. lm/orQ o 
ss Sll in the example of Fig. 23, (n + 1)/2 is used as v and 2 is used as u. The values v and u are ,n an inverse 
EEL relT^ rSve P to the modular calculation using the modulus n. Namely, v • u mod n - 1 . In the modrf.cation 
process (2307) by v, used during the first repetitive processes of a predetermined number is 
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v = 1 (23) 

so used during the following repetitive processes is 

v = v*(n + 1)/2 (24) 

t0082] If the modification by v = (n + 1)/2 is removed every third repetitive processes during the process (2318), 
then 

u = ((2 ** 4 * 2) 4 * 2) ** 4 * 2 (25) 

which results in 2 ** 85. As seen from the equation (25), in the processes shown in Fig. 23, y is multiplied by v in the 
unit of two bits because of the two-bit process, and the multiplication by v at the preceding processed (231 4 to 231 7) is 
removed. In the process (2318), the following equation is calculated every third repetitive processes, 

y = y * 2 ** 85 mod n (26) 

to remove the multiplication of t[i] by (n + 1)/2. If v is modified by ((n + 1)/2) ** 2 during the process (2307), the equation 
(25) is changed to 

u = (((2 ** 2) ** 4 * 2 ** 2) ** 4 * 2 ** 2) ** 4 * 2 ** 2 (27) 

and (2 ** 2) ** 85 = 2 * 1 70. In the process (231 8), the following equation is calculated every third repetitive processes 

25 y = y*2**170modn (28) 

so that the modification of t[i] multiplied by ((N + 1)/2 ) ** 2 is removed. The equations (25) and (27) use (n + 1)/2 as v 
and this value can be calculated beforehand. In the example of Fig. 23, the two-bit process for e is assumed, but a one- 
bit process, three-bit process or four-bit process may also be used in the examples shown in Figs. 21 to 23. 

30 [0083] The process (2318) shown in Fig. 23 is an example of the "inverse process unit" which operates at the inter- 
mediate operation stage and does not operate after the processes for all bits of e are completed. In Fig. 23, the equa- 
tions (21 to 28) are assumed to use v = (n + 1)/2 and u = 2. The processes (2202 and 2302) are an example of the 
"modular exponentiation process unit". The "modular exponentiation result change process unit" are realized by the 
processes 2207 and 2208 or the processes (2307 and 2308). The "modular multiplication process unit" is realized by 

35 the processes (2210 to 2217) or the processes (2310 to 2317). The "inverse process unit" is realized by the process 
(2218) or (2318). 

[0084] The embodiment described with reference to Figs. 21 to 23 is related to RSA. This embodiment may be 
applied to other cryptographic system using modular calculation, such as EIGamal cryptography. The modular expo- 
nentiation process unit" and "inverse process unit" shown in Figs. 21 to 23 may be used for more general modular cal- 
culations. Although the embodiment is based upon the addition chain method described in "Introduction of 
Cryptography Theory", by Eiji Okamoto, KYOURITSU Publication Co., at page 95, the embodiment is also applicable to 
general modular exponentiation calculation of one-bit process. 

[0085] The dependency of the wave shape of consumption current upon data during modular calculation is influ- 
enced not only by multipliers and multiplicands of modular multiplication but also by the value of a modulus N. Hiding 
45 the relation between the modulus value N and consumption current wave shape becomes necessary in order not to leak 
important information to the external. The following calculations are often used in the RSA cryptosystem or the like. 

y m a * b mod n (29) 

so [0086] The equation (29) is generalized to the following modular calculation. 

y = a mod n (30) 

[0087] This indicates that a remainder of a divided by n is y and equivalent to the following equation. 

55 

a = n*x + y (31) 
By multiplying both the sides by an arbitrary value r, the following equation is obtained. 
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a*r = n*x*r + y*r (32) 

By representing this equation by a modular calculation equation, the following equation is obtained. 

5 y * r = (a * r) mod (r * n) (33) 

This means that by multiplying the modulus N by r and the right side a by r, then the left side is also multiplied by r. One 
method of hiding the relation between the modulus data N and consumption current is to modify the modulus N. The 
equation (33) shows that if the modulus N is multiplied by r and the right side a is multiplied by r to perform a modular 

fo calculation, and if the result is divided by r, then the original y is obtained. In this manner, the relation between the mod- 
ulus value N and consumption current can be hidden. This is particularly effective when "Chinese remainder theorem" 
at page 96 of "Introduction of Cryptography Theory" by Eiji Okamoto, KYOURITSU Publishing Co. is used for the mod- 
ular calculation using prime factors p and q of a modulus N in the RSA calculation, to hide the information of p and q. 
[0088] This process sequence will be described with reference to Fig. 31 . First, a value r to be multiplied by N to 

15 modify it is acquired (3102). Next, in order to multiply the modulus N, it is multiplied by r (3103). The right side value is 
also multiplied by r (1304) to perform a modular calculation (3105). In order to recover the original value, the calculation 
result is divided by r (3106). 

[0089] The process (31 03) shown in Fig. 31 is an example of a modulus change process unit for changing the mod- 
ulus in a modular calculation, the process (3104) is an example of the value change process for changing the value of 
20 a right side of a modular calculation equation, and the process (3106) is an example of an inverse change unit for recov- 
ering the original modulus before it is changed by the modulus change process unit. In the example shown in Fig. 31 , 
in order to change the modulus in a modular calculation and the right side of the modular calculation equation, an arbi- 
trary value r is multiplied, and the inverse change unit divides the result by r. 

[0090] If r to be used for changing the modulus N is set to 2 raised to a certain power, then the process of multiply- 
25 ing the modulus N and the right side value by r is realized by a left shift by the number of bits corresponding to the 
power. The process of dividing the result by r is realized by a right shift. Since multiplication and division are not used, 
the calculation can be performed at high speed. If 2 raised to the eighth power is used as r, multiplication and division 
are realized not by a shift instruction but by a data move instruction, so that the calculation can be performed at higher 
speed. 

30 [0091 ] According to the invention, the process sequence of an IC card chip is randomized and a dummy process is 
added to modify the process data. Accordingly, it becomes difficult to presume the operation and cipher key by moni- 
toring the wave shape of consumption current. 

Claims 

35 

1 . An information processing equipment comprising: 

a storage memory including a program storage unit for storing a program and a data storage unit for storing 
data; and 

40 a central processing unit for executing a predetermined process in accordance with the program to process the 

d_ata, the program includingjDne or more date process means each having a process instruction for giving an 
execution instruction to said central processing unit, 

wherein the data are a combination of normal data and its bit inverted data which include data under a normal 
process and data obtained by inverting bits of the data under the normal process (Fig. 3). 

45 

2. An information processing equipment comprising: 

a storage memory including a program storage unit for storing a program and a data storage unit for storing 
data; and 

so a central processing unit for executing a predetermined process in accordance with the program to process the 

data, the program including one or more data process means each having a process instruction for giving an 
execution instruction to said central processing unit, 
wherein the data process means includes any of the following: 

55 (2. 1 ) normal data and bit inverted data process means (2806) for processing data under a normal process 

and data obtained by inverting bits of the data under the normal process, by using a same instruction; or 
(2.2) normal data instruction and bit inverted data instruction processing means having an instruction the 
same as a normal process instruction and an instruction for processing data obtained by inverting bits of 
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data to be processed by the normal process instruction (1 103, 1202; Fig. 25-26); or 

(2.3) bit inverted data generation means (1703; Fig. 25, 26) for generating data which are bit inverted data 
of data subjected to a normal process; or 

(2.4) repetitive random execution processing means (2402-2405) for randomly executing repetitive data 
5 processes; or 

(2.5) in the program, dummy execution process means (2402-2406) that does not affect processes to be 
executed by the program; or 

(2.6) modular exponentiation means for repetitively performing a modular multiplication by using input data 
and a cipher key, 

io modular multiplication process means (1906) for performing a modular multiplication of input data multi- 

plied by an intermediate modular calculation result irrespective of the value of bits of the cipher key, 
and modular multiplication result selection means (1907-1909) for using a modular multiplication result by 
said modular multiplication process means if the value of bits of the cipher key is 1, and neglecting said 
modular multiplication result if the value is 0. 

75 

3. The equipment of claim 2, wherein the data process means includes dummy execution and repetitive random exe- 
cution process means (2402-2406) for randomly executing dummy execution processes and repetitive data proc- 
esses. 



4. The equipment of claim 1 , wherein the data process means includes any of the following: 

(4.1) permutation means (Fig. 24) for permuting data in the unit of a bit; or 

(4.2) substitution means for substituting data in the unit of a byte; or 

(4.3) exclusive logical OR process means (801) for performing an exclusive logical OR of input data and cipher 
25 key data, and 

exclusive logical OR process means (901) for performing an exclusive logical OR of bit inverted input data and 
the cipher key data, or 

(4.4) non-linear substitution process means for nonlinearly substituting input data and generating a substitution 
result and bit inverted substitution result, 

30 and non-linear substitution process means for non-linearly substituting input bit inverted data and generating a 

substitution result and bit inverted substitution result (1101, 1201); or 

(4.5) non-linear permutation process means for non-linearly permuting input data and generating a permuta- 
tion result and a bit inverted permutation result, 

and non-linear permutation process means for non-linearly permuting input bit inverted data and generating a 
35 permutation result and a bit inverted permutation result (1401 , 1501); or 

(4.6) exclusive logical OR process means for performing an exclusive logical OR of input data and cipher key 
data; 

exclusive logical OR process means for performing an exclusive logical OR of bit inverted input data and the 
cipher key data; 

4. .__ non-linear substitution process means for non-linearly substituting input data and generating a substitution 

result and a bit inverted substitution result; 

non-linear substitution process means for non-linearly substituting input bit inverted data and generating a sub- 
stitution result and a bit inverted substitution result; 

non-linear permutation process means for non-linearly permuting input data and generating a permutation 
45 result and a bit inverted permutation result; and 

non-linear permutation process means for non-linearly permuting input bit inverted data and generating a per- 
mutation result and a bit inverted permutation result (402-405). 



5. An information processing equipment comprising: 

50 

a storage memory including a program storage unit for storing a program and a data storage unit for storing 
data; and 

a central processing unit for executing a predetermined process in accordance with the program to process the 
data, the program including one or more data process means each having a process instruction for giving an 
55 execution instruction to said central processing unit, the data process means performing a modular exponen- 

tiation calculation by using input data and a cipher key and including modular exponentiation process means 
(2102) for performing a modular exponentiation of input data in correspondence with each value of a plurality 
of bits and modular multiplication process means (2108-21 15) for performing a modular multiplication of the 
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modular exponentiation result by said modular exponentiation process means multiplied by an intermediate 
modular calculation result, 

wherein the data process means includes modular exponentiation result change process means for changing 
the modular exponentiation result at a timing while said modular multiplication process means processes. 

•nformation processing equipment comprising: 

a storage memory including a program storage unit for storing a program and a data storage unit for storing 
data; and 

a central processing unit for executing a predetermined process in accordance with the program to process the 
data, the program including one or more data process means each having a process instruction for giving an 
execution instruction to said central processing unit, the data process means including modular calculation 
process means, 

wherein the data process means includes modular exponentiation result change process means for modifying 
15 the modulus by changing input data corresponding to a bit. 

7. The equipment of claim 5 or 6, wherein the data process means includes inverse process means (2218) for recov- 
ering the modular exponentiation result before the result is changed by said modular exponentiation result change 
process means. 

20 

8. The equipment of claim 5 or 6, wherein said modular exponentiation result change process means adds an integer 
multiple of a modulus of a modular calculation to the modular exponentiation result. 

9. The equipment of claim 8, wherein 

25 said modular exponentiation result change process means performs a modular exponentiation of the mod- 

ular exponentiation result multiplied by v or v raised to a certain power among two values u and v whose modulus 
in the mutual modular calculation is 1 , and 

said inverse process means (2204, 2207, 2208) performs a modular exponentiation of u raised to a power 
whose order corresponds to the number of times during the modular multiplication through multiplication by v. 

30 

1 0. The equipment of claim 9, wherein said modular exponentiation result change process means uses two values 2 
and (N + 1)/2 whose modulus N in the mutual modular calculation is 1. 

1 1 . The equipment of claim 9, wherein 

35 said modular exponentiation process means (2202, 2302) performs a modular exponentiation of input data 

raised to a certain power corresponding to each of all combinations of M bits of 0 and 1 of the cipher key; 

said modular exponentiation result change process means (2207, 2208; 2307, 2308) executes at a certain 
timing a modular exponentiation of the modular exponentiation result multiplied by v or v raised to a certain power 
among two values u and v whose molecular multiplication by using the modulus N in the modular calculation is 1; 

40 said modular multiplication process means (2210-2207; 2310-231 7) performs a modular multiplication of the 

modular exponentiation result by said modular exponentiation process means multiplied by an intermediate modu- 
lar multiplication result in correspondence to each value of the M bits of the cipher key; and 

said inverse process means (2218, 2318) performs a modular exponentiation of u raised to a power whose 
order corresponds to the number of times during the modular multiplication through multiplication by v. 

45 

1 2. The equipment of claim 1 1 , wherein 

said modular exponentiation result change process means executes at a certain timing a modular exponen- 
tiation of the modular exponentiation result multiplied by v which takes an arbitrary binary power by using the mod- 
ulus N in the modular calculation, and 
so said inverse process means performs a modular exponentiation of (n + 1)/2 raised to a power whose order 

corresponds to the number of times during the modular multiplication through multiplication by 2. 

13. The equipment of claim 8, wherein said modular exponentiation result change process means adds the value of 
the modulus in the modular calculation multiplied by 2 raised to an arbitrary power or to the eighth power, to the 

55 modular exponentiation result. 

14. An information processing equipment comprising: 



JSDOCID: <EP 1006492A1J_> 



16 



EP 1 006 492 A1 



a storage memory including a program storage unit for storing a program and a data storage unit for storing 
data; and 

a central processing unit for executing a predetermined process in accordance with the program to process the 
data, the program including one or more data process means each having a process instruction for giving an 
5 execution instruction to said central processing unit, the data process means including modular calculation 

process means, 

wherein the data process means includes modulus change process means (3103) for modifying the modulus 
in a modular calculation; value change process means (3104) for changing the value of the right side of the 
modular calculation equation; and inverse process means (3106) for recovering the original modulus of the 
w modular calculation changed by said modulus change process means. 

15. The equipment of claim 14, wherein said modulus change process means multiplies the modulus by an integer, 
said value change process means multiplies the value of the right side by the integer, and said inverse process 
means divides the modular exponentiation result by the integer. 



15 



16. The equipment of claim 15, wherein each of said modulus change process means, said value change process, and 
said inverse process means uses 2 raised to an arbitrary power or to the eighth power as said integer. 

17. The equipment of any preceding claim, wherein the equipment is an IC card. 
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